<?php

namespace App\Jobs\Publish;

use App\Models\Entity\Asset\Video\Vseriali;
use App\Models\Task\Task;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Queue\SerializesModels;
use Illuminate\Support\Facades\DB;
use App\Classes\Publish\Publication;

class VserialiJob implements ShouldQueue
{
    use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
    protected $ids;
    protected $option;
    public $tries   = 1;
    public $timeout = 30;
    public $taskid;
    // 上线,下线,发布的where条件
    protected $upWhere          = ['online_status' => 0, 'publish_down_status' => 1];
    protected $publishWhere     = ['online_status' => 1, 'publish_status'      => 0, 'async_result' => 1];
    protected $downWhere        = ['online_status' => 1];
    protected $publishDownWhere = ['online_status' => 0, 'publish_down_status' => 0];
    /**
     * Create a new job instance.
     *
     * @return void
     */
    public function __construct($option, $ids = '', $taskid = '')
    {
        $this->option = $option;
        $this->ids    = $ids;
        $this->taskid = $taskid;
    }

    /**
     * Execute the job.
     *
     * @return void
     */
    public function handle()
    {
        switch ($this->option[0]) {
            // 分发任务,将一个大任务划分为多个小任务
            case 'dispatch':
                $this->mydispatch($this->option[1]);
                break;
            // 上线小任务
            case 'up':
                $user_id = Publication::getField(new Task(), $this->taskid, 'user_id');
                Publication::updateMany(new Vseriali(), $this->ids, [
                    'online_status'       => 1, 
                    'publish_down_status' => 0, 
                    'user_id'             => $user_id, 
                    'online_at'           => date('Y-m-d H:i:s')
                ]);
                Publication::updateOne(new Task(), $this->taskid, [
                    'done_num' => DB::raw('done_num +'.count($this->ids)),
                ]);
                break;
            // 发布小任务
            case 'publish':
                $publish_small_chunk_num = config('custom.base.job.vseriali.publish_small_chunk_num');
                foreach ($this->ids->chunk($publish_small_chunk_num) as $chunk_ids) {
                    try {
                        $vserialis = Vseriali::with(['vposteris', 'vifiles'])->whereIn('id', $chunk_ids)->get();
                    } catch(\Exception $e) {
                        dd($e->getMessage());
                    }
                    // 拼装产品包数据, 产品包-媒资中间表数据
                    $vseriali_datas = self::makeVserialis($vserialis);
                    DB::connection('interface')->beginTransaction();
                    try {
                        DB::connection('interface')->table('vserialis')->insert($vseriali_datas);
                        DB::connection('interface')->commit();
                        Publication::updateMany(new Vseriali(), $chunk_ids, ['publish_status' => 1]);
                        Publication::updateOne(new Task(), $this->taskid, [
                            'done_num' => DB::raw('done_num + '.count($chunk_ids))
                        ]);
                    } catch (\Exception $e) {
                        DB::connection('interface')->rollback(); //事务回滚
                        dd($e->getMessage());
                    }
                }
                break;
            // 下线小任务
            case 'down':
                $user_id = Publication::getField(new Task(), $this->taskid, 'user_id');
                Publication::updateMany(new Vseriali(), $this->ids, [
                    'online_status'  => 0, 
                    'publish_status' => 0, 
                    'user_id'        => $user_id, 
                    'offline_at'     => date('Y-m-d H:i:s')
                ]);
                Publication::updateOne(new Task(), $this->taskid, ['done_num' => DB::raw('done_num +' . count($this->ids))]);
                break;
            // 下线发布小任务
            case 'publishDown':
                $user_id = Publication::getField(new Task(), $this->taskid, 'user_id');
                Publication::deleteApi('vserialis', 'vseriali_id', $this->ids);
                Publication::updateMany(new Vseriali(), $this->ids, [
                    'publish_down_status' => 1, 
                    'user_id'             => $user_id, 
                ]);
                Publication::updateOne(new Task(), $this->taskid, ['done_num' => DB::raw('done_num +' . count($this->ids))]);
                break;
        }
    }
    
    /**
    * 分发任务具体执行代码
    */
    public function mydispatch($option)
    {
        switch ($option) {
            case 'up':
                $chunk_num = config('custom.base.job.vseriali.online_chunk_num');
                $where = $this->upWhere;
                break;
            case 'publish':
                $chunk_num = config('custom.base.job.vseriali.publish_chunk_num');
                $where = $this->publishWhere;
                break;
            case 'down':
                $chunk_num = config('custom.base.job.vseriali.offline_chunk_num');
                $where = $this->downWhere;
                break;
            case 'publishDown':
                $chunk_num = config('custom.base.job.vseriali.publish_chunk_num');
                $where = $this->publishDownWhere;
                break;
        }
        Publication::chunk(new Vseriali(), $this, $where, $chunk_num, [$option]);
    }
      
    /**
    * 拼装数据
    */
    public static function makeVserialis($vserialis)
    {
        $datas = [];
        $data  = [];
        foreach ($vserialis as $vseriali) {
            // 服务商ID 目前服务商ID是瀚动的
            $data['sp_id']         = 1;
            // 剧集ID(可以理解为总集)
            $data['vasseti_id']    = $vseriali->vasseti_id;
            // 分集id
            $data['vseriali_id']   = $vseriali->id;
            // 分集编号
            $data['vseriali_no']   = $vseriali->vseriali_no;
            // 标题
            $data['title']         = $vseriali->title;
            // 副标题
            $data['subtitle']      = $vseriali->subtitle;
            // 评分
            $data['score']         = $vseriali->score;
            // 详情
            $data['long_desc']     = $vseriali->long_desc;
            // 简述
            $data['short_desc']    = $vseriali->short_desc;
            // 第几集
            $data['episode']       = $vseriali->episode;
            // 媒资注入之后的信息
            $data['async_content'] = $vseriali->async_content;
            // 根据图片的类型, 分为1:海报,2:剧照
            if ($vseriali->vposteris->first()) {
                $temp            = $vseriali->vposteris->groupBy('vimgtag_id');
                $data['posters'] = $temp->get(1) ? $temp->get(1)->toJson() : '';
                $data['imgs']    = $temp->get(2) ? $temp->get(2)->toJson() : '';
                unset($temp);
            } else {
                $data['imgs']    = '';
                $data['posters'] = '';
            }
            // 流
            $data['streams'] = '';
            // 音频文件
            if ($vseriali->vifiles->first()) {
                $data['vifiles'] = json_encode($vseriali->vifiles);
            } else {
                $data['vifiles'] = '';
            }
            $data['vseriali_page_view'] = 0;
            $datas[]                    = $data;
        }
        return $datas;
    }
}
